<template>
  <div id="app">
    <router-view/>
  </div>
</template>

<script setup>
// 应用根组件
</script>

<style>
/* CSS变量 - 管理端配色方案 */
:root {
  /* 主色系 - 专业蓝色 */
  --admin-primary: #1890ff;
  --admin-primary-light: #40a9ff;
  --admin-primary-dark: #096dd9;
  --admin-primary-bg: #e6f7ff;
  --admin-primary-hover: #40a9ff;

  /* 辅助色 */
  --admin-success: #52c41a;
  --admin-success-light: #73d13d;
  --admin-success-bg: #f6ffed;
  --admin-warning: #faad14;
  --admin-warning-light: #ffc53d;
  --admin-warning-bg: #fffbe6;
  --admin-error: #ff4d4f;
  --admin-error-light: #ff7875;
  --admin-error-bg: #fff2f0;
  --admin-info: #1890ff;

  /* 中性色 */
  --admin-text-primary: #262626;
  --admin-text-secondary: #595959;
  --admin-text-tertiary: #8c8c8c;
  --admin-text-quaternary: #bfbfbf;
  --admin-text-disabled: #d9d9d9;

  /* 背景色 */
  --admin-bg-primary: #ffffff;
  --admin-bg-secondary: #fafafa;
  --admin-bg-tertiary: #f5f5f5;
  --admin-bg-layout: #f0f2f5;
  --admin-bg-hover: #f5f5f5;

  /* 边框色 */
  --admin-border-light: #f0f0f0;
  --admin-border-medium: #d9d9d9;
  --admin-border-dark: #bfbfbf;
  --admin-border-focus: #40a9ff;

  /* 阴影 */
  --admin-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.06);
  --admin-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  --admin-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);
  --admin-shadow-hover: 0 4px 16px rgba(0, 0, 0, 0.1);

  /* 圆角 */
  --admin-radius-sm: 4px;
  --admin-radius-md: 6px;
  --admin-radius-lg: 8px;
  --admin-radius-xl: 12px;

  /* 间距 */
  --admin-space-xs: 4px;
  --admin-space-sm: 8px;
  --admin-space-md: 16px;
  --admin-space-lg: 24px;
  --admin-space-xl: 32px;
  --admin-space-xxl: 48px;

  /* 字体大小 */
  --admin-font-xs: 12px;
  --admin-font-sm: 14px;
  --admin-font-md: 16px;
  --admin-font-lg: 18px;
  --admin-font-xl: 20px;
  --admin-font-xxl: 24px;

  /* 字体权重 */
  --admin-font-normal: 400;
  --admin-font-medium: 500;
  --admin-font-semibold: 600;
  --admin-font-bold: 700;

  /* 行高 */
  --admin-line-height-sm: 1.2;
  --admin-line-height-md: 1.5;
  --admin-line-height-lg: 1.8;

  /* 组件高度 */
  --admin-height-sm: 32px;
  --admin-height-md: 40px;
  --admin-height-lg: 48px;
  --admin-height-xl: 56px;
}

/* 全局样式重置 */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  height: 100%;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  font-size: 14px;
  color: var(--admin-text-primary);
  background-color: var(--admin-bg-layout);
  line-height: 1.5715;
}

#app {
  height: 100%;
}

/* 滚动条样式 - 自动隐藏 */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: transparent;
  border-radius: 4px;
}

::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.15);
  border-radius: 4px;
  transition: all 0.3s ease;
  opacity: 0;
}

*:hover::-webkit-scrollbar-thumb {
  opacity: 1;
  background: rgba(0, 0, 0, 0.25);
}

*:hover::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.35);
}

/* Element Plus 样式覆盖 */
.el-button {
  font-weight: 500;
  border-radius: var(--admin-radius-md);
}

.el-button--primary {
  background-color: var(--admin-primary);
  border-color: var(--admin-primary);
}

.el-button--primary:hover {
  background-color: var(--admin-primary-light);
  border-color: var(--admin-primary-light);
}

.el-card {
  border-radius: var(--admin-radius-lg);
  box-shadow: var(--admin-shadow-sm);
  border: 1px solid var(--admin-border-light);
}

.el-card__header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--admin-border-light);
  background-color: var(--admin-bg-secondary);
  font-weight: 600;
  color: var(--admin-text-primary);
}

.el-card__body {
  padding: 20px;
}

.el-form-item__label {
  font-weight: 500;
  color: var(--admin-text-primary);
}

.el-input__wrapper {
  border-radius: var(--admin-radius-md);
  box-shadow: var(--admin-shadow-sm);
}

.el-input__wrapper:hover {
  border-color: var(--admin-primary-light);
}

.el-input__wrapper.is-focus {
  border-color: var(--admin-primary);
  box-shadow: 0 0 0 2px var(--admin-primary-bg);
}

.el-select .el-input__wrapper {
  cursor: pointer;
}

.el-input-number {
  width: 100%;
}

.el-input-number .el-input__wrapper {
  padding-left: 11px;
  padding-right: 40px;
}

.el-table {
  border-radius: var(--admin-radius-lg);
  overflow: hidden;
}

.el-table th.el-table__cell {
  background-color: var(--admin-bg-secondary);
  color: var(--admin-text-primary);
  font-weight: 600;
  border-bottom: 1px solid var(--admin-border-medium);
}

.el-table .el-table__row:hover > td {
  background-color: var(--admin-bg-secondary);
}

.el-pagination {
  justify-content: flex-end;
}

.el-pagination .el-pager li {
  border-radius: var(--admin-radius-sm);
  margin: 0 2px;
}

.el-pagination .el-pager li.is-active {
  background-color: var(--admin-primary);
  color: white;
}

/* 管理端页面通用样式 */
.page-container {
  padding: 24px;
  background: var(--admin-bg-layout);
  min-height: 100vh;
}

.page-header {
  margin-bottom: 24px;
  padding: 20px 24px;
  background: var(--admin-bg-primary);
  border-radius: var(--admin-radius-lg);
  box-shadow: var(--admin-shadow-sm);
}

.page-title {
  margin: 0;
  color: var(--admin-text-primary);
  font-size: 20px;
  font-weight: 600;
}

.page-subtitle {
  color: var(--admin-text-secondary);
  margin: 8px 0 0 0;
  font-size: 14px;
}

.table-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
  padding: 16px 20px;
  background: var(--admin-bg-primary);
  border-radius: var(--admin-radius-lg);
  box-shadow: var(--admin-shadow-sm);
}

.table-toolbar-left {
  display: flex;
  gap: 12px;
  align-items: center;
}

.table-toolbar-right {
  display: flex;
  gap: 12px;
}

.pagination-container {
  margin-top: 20px;
  text-align: right;
  padding: 16px 20px;
  background: var(--admin-bg-primary);
  border-radius: var(--admin-radius-lg);
  box-shadow: var(--admin-shadow-sm);
}

/* 工具类 */
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

.mb-10 {
  margin-bottom: 10px;
}

.mb-20 {
  margin-bottom: 20px;
}

.mt-10 {
  margin-top: 10px;
}

.mt-20 {
  margin-top: 20px;
}

.flex {
  display: flex;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
</style>